File association

A file association associates a file with an application capable of opening that file. More commonly, a file association associates a class of files (usually determined by their filename extension, such as .txt) with a corresponding application (such as a text editor).

Contents

Associations and verbs

A single file extension may have several associations for performing various actions, also known as verbs. Some of the common verbs are:

A picture, for example, may be associated with these verbs so that open opens the picture in an image viewer, edit opens up an image editing program and print sends the picture to a printer.

Implementations

Most operating systems support file associations in some form or the other. For example, opening a file from a file manager usually invokes the open verb in order to open the file with its associated application. Additional actions such as print are usually accessed via a right-click context menu. A mechanism for modifying associations is also usually present. An example for this is the Open With option in the Windows Shell.

Microsoft Windows

The Microsoft Windows series of operating systems, beginning with Windows 3.x supports file extension-based associations.[1] Associations are stored in registry as sets of verbs for each file extension. Older versions supported open associations stored in WIN.INI. File associations can be displayed and edited using the assoc command and with the help of the ftype command it is possible to create association between file type and application which will open files of this type.[2]

The Windows shell invokes file association actions through COM, drag and drop, command line calls or through Dynamic Data Exchange. Advanced features of Microsoft Windows file associations included manually defining a new file extension with any number of associated actions, a primary default action, showing extensions only for specific file types, customizing the file type icon and description and customizing associated MIME type and their handling (how to handle file types for files downloaded or directly opened from within the Internet Explorer browser). The ability to configure advanced file association functionality, however, was removed in Windows Vista and later operating systems.[3]

Linux

Linux-based GUIs, such as KDE and GNOME, support MIME type-based associations. For example, the MIME type text/plain might be associated with a text editor.

Mac OS

Classic Mac OS used type codes and creator codes to associate each file with its corresponding application, regardless of file extension. The more recent Mac OS X also supports file extension–based associations.

Application bundles in OS X declare supported file types in their Info.plist file. For each of these specified types, a Uniform Type Identifier is given, along with a list of 'tags' which define how a file or data of this type could be identified. For example, the JPEG type is defined with a UTI of 'public.jpeg', and tagged with the extensions 'jpg' and 'jpeg', the MIME type 'image/jpeg' and the type code 'JPEG'.[4]

The operating system uses this information to generate a list of applications which are able to open each type. Within Finder each file will be identified with a UTI and open with the default application for that type. The user may also select from a list of other applications which support the type.

Using this system, types are also associated with data for which there is no file name or the file extension is missing. This includes pasteboard data and data streaming over a protocol such as HTTP where a MIME type has been given.

See also

References

Further reading

  1. "Implementing a Custom File Format". Microsoft Developer Network Library. Microsoft Corporation. 9 November 2010. http://msdn.microsoft.com/en-us/library/ff521657(v=VS.85).aspx. Retrieved 5 December 2010. 
  2. "Customizing KDE: File Associations". KDE Documentation. KDE. 4 February 2008. http://docs.kde.org/userguide/file-associations.html. Retrieved 5 December 2010.